## Amendments to the Claims:

From-PHILIPS ELECTRONICS ICS

These claims will replace all prior versions, and listings, of claims in the application:

1-20. (Canceled)

21. (Previously presented) A program segment stored on a computer readable medium for cryptographically converting a digital input data block M into a digital output data block; said program segment comprising:

a program portion for merging a selected part M1 of said digital input data block M with a first digital key K1 to produce a data block B1 which non-linearly depends on said selected part M1 and said first digital key K1; and

a program portion for deriving said digital output block from said data block B1 and the remaining part of the digital input data block M, wherein said merging step is performed by executing a non-linear function g for non-linearly merging said selected part M1 and said first key K1 in a single step.

- 22. (Previously presented) A program segment as claimed in claim 21, comprising:
- a program portion for splitting said digital input block into said selected part M1 and a second part M2 before executing said program portion for merging;

a program portion for executing a non-linear function g<sup>-1</sup> to merge said second block M2 with a second key K2 in one step, producing a data block B2 as output; said non-linear function g-1 being the inverse of said non-linear function g; and

Serial No. 09/924,990 Page 3 of 10

a program portion for forming combined data from data in said data block B1 and in said data block B2; said digital output block being derived from said combined data.

- 23. (Currently amended) A program segment as claimed in claim 21, wherein said program portion for merging comprises:
- a program portion for splitting said selected part M1 in a first plurality n of sub-blocks  $m_0,...,m_{n-1}$  of substantially equal length;
- a program portion for splitting said first key K1 in said first plurality n of sub-keys  $k_0,...,k_{n-1}$ , substantially having equal length, the sub-key  $k_i$  corresponding to the sub-block  $m_i$ , for i = 0 to n-1:
- a program portion for separately processing each of said sub-blocks  $m_i$  by executing for each of said sub-blocks  $m_i$  a same non-linear function h for non-linearly merging a sub-block  $b_i$  derived from said sub-block  $m_i$  with said corresponding sub-key  $k_i$  in one, sequentially inseparable step and producing said first plurality of output sub-blocks  $h(b_i, k_i)$ ; and
- a program portion for combining sub-blocks t<sub>i</sub> derived from said first plurality of said output sub-blocks h(b<sub>i</sub>, k<sub>i</sub>) to form said data block B1.
- 24. (Currently amended) A program segment as claimed in claim 22, wherein said program portion for executing said non-linear function g<sup>-1</sup> comprises:
- a program portion for splitting said second part M2 in said first plurality n of sub-blocks  $m_0,...,m_{2n-1}$ , substantially having equal length;

Serial No. 09/924,990 Page 4 of 10

a program portion for splitting said key K2 in said first plurality n of sub-keys k<sub>1</sub>,...k<sub>2n-1</sub>, substantially having equal length, the sub-key  $k_i$  corresponding to the sub-block  $m_i$ , for i = n to 2n-1;

a program portion for executing for each of said sub-blocks m; a same non-linear function h' for non-linearly merging a sub-block bi derived from said sub-block mi with said corresponding sub-key k; and producing said first plurality of an output sub-block h-1(bi, ki); said function h<sup>-1</sup> being the inverse of said function h; and

a program portion for combining sub-blocks ti derived from said first plurality of output sub-blocks h<sup>-1</sup>(b<sub>i</sub>, k<sub>i</sub>) to form said data block B2.

- A program segment as claimed in claim 23, wherein said 25. (Currently amended) sub-block bi is derived from said sub-block mi by bit-wise adding a constant pi to said sub-block mi, said constant pi substantially having equal length as said sub-block mi.
- 26. (Previously presented) A program segment as claimed in claim 23, characterised in that said function  $h(b_i,k_i)$  is defined by:

$$h(b_i,k_i)=\left(b_i.k_i\right)^{-1}, \qquad \text{ if } b_i\neq 0, \ k_i\neq 0, \ \text{and } b_i\neq k_i$$

$$h(b_i,k_i) = (k_i)^{-2},$$
 if  $b_i = 0$ 

From-PHILIPS ELECTRONICS ICS

$$h(b_i,k_i) = (b_i)^{-2},$$
 if  $k_i = 0$ 

$$h(b_i,k_i) = 0, if b_i = k_i,$$

where the multiplication and inverse operations are predetermined Galois Field multiplication and inverse operations.

914-332-0615

Serial No. 09/924,990 Page 5 of 10

- 27. (Currently amended) A program segment as claimed in claim 26, wherein deriving said sub-blocks  $t_i$  from said output sub-blocks  $h(b_i, k_i)$  comprises bit-wise adding a constant  $d_i$  to said output sub-block  $h(b_i, k_i)$ , said constant  $d_i$  substantially having equal length as said sub-block  $m_i$ .
- 28. (Previously presented) A program segment as claimed in claim 27, wherein deriving said sub-blocks  $t_i$  from said output sub-blocks  $h(b_i, k_i)$  further comprises raising  $h(b_i, k_i) \oplus d_i$  to a power  $2^i$ , using said predetermined Galois Field multiplication.
- 29. (Previously presented) A program segment as claimed in claim 26, wherein deriving said sub-blocks  $t_i$  from said output sub-blocks  $h(b_i, k_i)$  comprises raising said output sub-block  $h(b_i, k_i)$  to a power  $2^i$ , using said predetermined Galois Field (GF) multiplication.
- 30. (Currently amended) A program segment as claimed in claim 24, wherein said combined data is formed by:

swapping the sub-blocks  $t_i$  and  $t_{2n-1-i}$ , for i=0 to n-1; and concatenating the swapped sub-blocks.

31. (Previously presented) A program segment as claimed in claim 26, wherein said sub-block m<sub>i</sub> comprises eight data bits, and wherein said multiplying of two elements b and c of  $GF(2^8)$  comprises executing a series of multiplications and additions in  $GF(2^4)$ .

32. (Previously presented) A program segment as claimed in claim 31, wherein said multiplying of said two elements b and c comprises:

representing b as  $a_0 + a_1.D$  and c as  $a_2 + a_3.D$ , where  $a_0$ ,  $a_1$ ,  $a_2$  and  $a_3$  are elements of  $GF(2^4)$ , and where D is an element of  $GF(2^8)$  defined as a root of an irreducible polynomial  $k(x) = x^2 + x + \beta$  over  $GF(2^4)$ , where  $\beta$  is an element of  $GF(2^4)$ ; and calculating  $(a_0a_2 + a_1a_3\beta) + (a_1a_2 + a_0a_3 + a_1a_3).D$ .

- 33. (Previously presented) A program segment as claimed in claim 32, wherein  $\beta$  is a root of an irreducible polynomial  $h(x) = x^4 + x^3 + x^2 + x + 1$  over GF(2).
- 34. (Previously presented) A program segment as claimed in claim 26, wherein said sub-block  $m_i$  comprises eight data bits, and wherein calculating the inverse of an element b of  $GF(2^8)$  comprises performing a series of calculations in  $GF(2^4)$ .
- 35. (Previously presented) A program segment as claimed in claim 34, wherein calculating the inverse of said element b comprises:

representing b as  $a_0 + a_1.D$ , where  $a_0$  and  $a_1$  are elements of  $GF(2^4)$ , and where D is an element of  $GF(2^8)$  defined as a root of an irreducible polynomial  $k(x) = x^2 + x + \beta$  over  $GF(2^4)$ , where  $\beta$  is an element of  $GF(2^4)$ ; and

calculating  $(a_0^2 + a_0a_1 + a_1^2\beta)^{-1}((a_0 + a_1) + a_1D)$ .

36. (Currently amended) A processor for cryptographically converting a digital input block into a digital output block; said processor comprising:

Serial No. 09/924,990 Page 7 of 10

a first input means for obtaining said digital input block:

From-PHILIPS ELECTRONICS ICS

- a second input means for obtaining a first key K1; and
- a cryptographic processing portion means arranged to convert the digital input block into the digital output block by executing a non-linear function g for non-linearly merging said selected part M1 and said first key K1 in one step and producing a data block B1 which nonlinearly depends on said selected part M1 and said first key K1, where a selected part of said digital output block is derived from said data block B1.
- 37. (Currently amended) A processor as claimed in claim 36, wherein said processor comprises a third input means for obtaining a second key K2, and wherein said processor is arranged to:

split said digital input block into said selected part M1 and a second part M2 before performing said merging;

perform a non-linear function g<sup>-1</sup> to merge said second block M2 with said second key K2 in one step, producing a data block B2 as output; said non-linear function g-1 being the inverse of said non-linear function g; and

combine data from data in said data block B1 and in said data block B2; said digital output block being derived from said combined data.

A processor as claimed in claim 36, wherein said merging 38. (Currently amended) comprises:

splitting said selected part M1 in a first plurality n of sub-blocks m<sub>0</sub>,...,m<sub>n-1</sub> of substantially equal length;

Page 8 of 10

splitting said first key K1 in said first plurality n of sub-keys k0,..,kn-1, substantially having equal length, the sub-key k<sub>i</sub> corresponding to the sub-block m<sub>i</sub>, for i = 0 to n-1; and

separately processing each of said sub-blocks mi by executing for each of said sub-blocks m, a same non-linear function h for non-linearly merging a sub-block b; derived from said subblock m; with said corresponding sub-key k; in one, sequentially inseparable step and producing said first plurality of output sub-blocks h(bi, ki); and

combining sub-blocks ti derived from said first plurality of said output sub-blocks h(bi, ki) to form said data block B1.

39. (Previously presented) A processor as claimed in claim 38, wherein said function  $h(b_i,k_i)$  is defined by:

$$h(b_i,k_i) = (b_i,k_i)^{-1},$$
 if  $b_i \neq 0$ ,  $k_i \neq 0$ , and  $b_i \neq k_i$ 

From-PHILIPS ELECTRONICS ICS

$$h(b_i,k_i) = (k_i)^{-2},$$
 if  $b_i = 0$ 

$$h(b_i,k_i) = (b_i)^{-2},$$
 if  $k_i = 0$ 

$$h(b_i,k_i) = 0, if b_i = k_i,$$

where the multiplication and inverse operations are predetermined Galois Field multiplication and inverse operations.

40. (Previously presented) A processor as claimed in claim 39, wherein said sub-block m<sub>i</sub> comprises eight data bits, and wherein said multiplying of two elements b and c of GF(2<sup>8</sup>) comprises:

Serial No. 09/924,990 Page 9 of 10

representing b as  $a_0 + a_1.D$  and c as  $a_2 + a_3.D$ , where  $a_0$ ,  $a_1$ ,  $a_2$  and  $a_3$  are elements of  $GF(2^4)$ , and where D is an element of  $GF(2^8)$  defined as a root of an irreducible polynomial  $k(x) = x^2 + x + \beta$  over  $GF(2^4)$ , where  $\beta$  is an element of  $GF(2^4)$ ; and

calculating  $(a_0a_2 + a_1a_3\beta) + (a_1a_2 + a_0a_3 + a_1a_3).D$ ;

From-PHILIPS ELECTRONICS ICS

and wherein calculating the inverse of an element b of GF(2<sup>8</sup>) comprises calculating  $(a_0^2 + a_0 a_1 + a_1^2 \beta)^{-1}((a_0 + a_1) + a_1 D)$ .